import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * 56.合并区间
 */
public class Exerciser2 {
    public int[][] merge(int[][] intervals) {
        // 1.排序按照第一个数据的大小
        Arrays.sort(intervals,(v1, v2) -> {
            return v1[0] - v2[0];
        });

        // 合并，求并集
        int left = intervals[0][0],right = intervals[0][1];
        List<int[]> ret = new ArrayList<>();
        for(int i = 1;i < intervals.length;i++) {
            int a = intervals[i][0],b = intervals[i][1];
            if(a <= right) {
                // 存在交集
                right = Math.max(right,b);
            }else {
                // 不存在交集
                ret.add(new int[]{left,right});
                right = b;
                left = a;
            }
        }
        // 最后一个区间是没有进行放入到ret中的，要进行处理
        ret.add(new int[]{left,right});
        return ret.toArray(new int[0][]);
    }
}
